/**
 * 相关企业
 * 在一条环路上有 n 个加油站，其中第 i 个加油站有汽油 gas[i] 升。
 *
 * 你有一辆油箱容量无限的的汽车，从第 i 个加油站开往第 i+1 个加油站需要消耗汽油 cost[i] 升。你从其中的一个加油站出发，开始时油箱为空。
 *
 * 给定两个整数数组 gas 和 cost ，如果你可以绕环路行驶一周，则返回出发时加油站的编号，否则返回 -1 。如果存在解，则 保证 它是 唯一 的。
 * 题解：https://labuladong.gitee.io/algo/3/29/103/
 */
class CanCompleteCircuit {
    /**
     * 法一：图像法
     * @param gas
     * @param cost
     * @return
     */
    public int canCompleteCircuitOne(int[] gas, int[] cost) {
        int n=gas.length;
        int sum=0;
        int minSum=0;
        int start=0;
        for(int i=0;i<n;i++) {
            sum+=(gas[i]-cost[i]);
            if(sum<minSum) {
                start=i+1;
                minSum=sum;
            }
        }
        if(sum<0) {
            return -1;
        }
        return start==n?0:start;
    }

    /**
     * 法二：贪心解法
     * @param gas
     * @param cost
     * @return
     */
    public int canCompleteCircuitTwo(int[] gas,int[] cost) {
        int n=gas.length;
        int sum=0;
        for(int i=0;i<n;i++) {
            sum+=(gas[i]-cost[i]);
        }
        if(sum<0) {
            return -1;
        }
        int tank=0;
        int start=0;
        for(int i=0;i<n;i++) {
            tank+=(gas[i]-cost[i]);
            if(tank<0) {
                tank=0;
                start=i+1;
            }
        }
        return start==n?0:start;
    }
}